草庐IT

JavaScript event.currentTarget 对比这个

全部标签

c# - 在 DDD 方法中,这个示例是否正确建模?

刚刚在SO上创建了一个acc来问这个:)假设这个简化示例:构建一个Web应用程序来管理项目...该应用程序具有以下要求/规则。1)用户应该能够通过插入项目名称来创建项目。2)项目名称不能为空。3)两个项目不能重名。我正在使用4层架构(用户界面、应用程序、域、基础架构)。在我的应用层上,我有以下ProjectService.cs类:publicclassProjectService{privateIProjectRepositoryProjectRepo{get;set;}publicProjectService(IProjectRepositoryprojectRepo){Projec

c# - 我怎样才能模拟这个静态方法

我有这个代码:publicstaticboolIsValidVoucher(stringid){//readtsvfilesvartemp1=AppData.GetAppData("stringval");//codethatneedtobetestedreturntrue;}我喜欢创建单元测试,但我如何模拟AppData.GetAppData("stringval")到我想要的任何值,这样我就可以测试其余代码。AppData类是:publicclassAppData{publicstaticobjectGetAppData(stringname){//...}}

c# - Base Controller ASP.NET MVC 3 中的这个 Custom Principal 是不是非常低效?

尽管我已经在这里待了一段时间,但这是我关于SO的第一个问题,所以请多多包涵。我正在使用ASP.NETMVC3并且我想创建一个自定义的Principal这样我就可以存储比标准更多的关于当前用户的信息因此不必经常去数据库。这是我追求的相当标准的东西。我们先说电子邮件地址和用户ID。我决定将对象存储在缓存中,因为我知道不建议将其存储在session中。我也不想一直转换User对象,所以我想覆盖Controller中的User对象。所以我可以直接访问User.UserId并得到一些保证。所以我创建了一个这样的自定义主体:publicclassMyPrincipal:IPrincipal{pub

c# - 为什么这个内存管理技巧有效?

引用thisUnitydocumentation并转到部分Largeheapwithslowbutinfrequentgarbagecollectionvartmp=newSystem.Object[1024];//makeallocationsinsmallerblockstoavoidthemtobetreatedinaspecialway,whichisdesignedforlargeblocksfor(inti=0;i诀窍是在程序启动时预先分配一些内存块。为什么这个技巧有效?当block被预分配时,它们是否以某种方式“注册”(或“绑定(bind)”)到应用程序,因此即使tmp在

c# - 为什么这个对象的类型通过反射显示没有接口(interface),尽管至少实现了两个?

首先,一个按预期工作的示例:(所有代码都在VS2008即时窗口中执行)25isIComparable>>true25.GetType().GetInterfaces()>>{System.Type[5]}>>[0]:{Name="IComparable"FullName=...>>[1]:{Name="IFormattable"FullName=...>>...到目前为止一切顺利。现在让我们尝试一个通过基类型继承接口(interface)的对象:classTestBase:IComparable{publicintCompareTo(objectobj){thrownewNotImpl

c# - 为什么这个赋值不是线程安全的?

我一直在阅读JosephAlbahari关于线程的这本书:http://www.albahari.com/threading/在第2部分中,我找到了这个示例:http://www.albahari.com/threading/part2.aspx#_When_to_Lock这是前面提到的例子:classThreadUnsafe{staticint_x;staticvoidIncrement(){_x++;}staticvoidAssign(){_x=123;}}线程安全版本:classThreadSafe{staticreadonlyobject_locker=newobject();

c# - 为什么在这个简单的测试中,方法的速度与触发顺序有关?

我一直在做其他实验,直到这种奇怪的行为引起了我的注意。代码在x64版本中编译。如果键入1,List方法的第3次运行比前2次多花费40%的时间。输出是Listcosts9312Listcosts9289Arraycosts12730Listcosts11950如果键入2,Array方法的第3次运行比前2次多花费30%的时间。输出是Arraycosts8082Arraycosts8086Listcosts11937Arraycosts12698可以看到模式,完整的代码附在下面(编译运行即可):{提供的代码对于运行测试来说是最少的。用于获得可靠结果的实际代码更复杂,我包装了该方法并在适当预热

c# - 我在这个谓词链中缺少什么?

注意:就在发布这个问题之前,我突然想到有一种更好的方法来完成我想要完成的事情(我觉得这很愚蠢):IEnumerablecheckedItems=ProductTypesList.CheckedItems.Cast();filter=p=>checkedItems.Contains(p.ProductType);好吧,是的,我已经意识到了这一点。但是,无论如何我都会发布这个问题,因为我仍然不太明白为什么我(愚蠢地)尝试做的事情没有奏效。我认为这会非常容易。原来这让我很头疼。基本思路:在CheckedListBox中显示所有ProductType属性值被选中的项目。实现:privateFu

c# - 我通过 COM 互操作获得的这个 `Object[*]` 类型是什么?

我做C#excel互操作。我从C#中调用宏,并且期望对象数组。我能够从返回二维数组的宏中获取二维对象数组。但是,另一个(第三方)宏应该返回一个一维数组。我无法让(object[])xlApp.Run(...)工作(它抛出异常),并且调试器中的类型信息表明结果是类型对象[*]。来自异常的实际消息是Unabletocastobjectoftype'System.Object[*]'totype'System.Object[]'.这是什么Object[*]类型以及如何从中检索一维数组?编辑:我想到这可能意味着SAFEARRAYofVARIANTS。但是随后出现了两个问题:为什么二维数组一切正

c# - 如何解决这个不明确的调用错误

我在编译时收到以下错误。我该如何解决它而不必求助于不同的函数名称privatedoubleSomeMethodName(SomeClassTypevalue){return0.0;}privatedoubleSomeMethodName(ADifferentClassTypevalue){if(value==null){returnthis.SomeMethodName(null);// 最佳答案 编译器很困惑,因为null匹配两个重载。您可以显式地将null转换为您需要的类,让编译器知道您正在调用两个重载中的哪一个:if(valu